package cn.iocoder.yudao.module.ems.service.spares;

import java.util.*;
import javax.validation.*;

import cn.iocoder.yudao.module.ems.controller.admin.eqtype.vo.EqTypeListReqVO;
import cn.iocoder.yudao.module.ems.controller.admin.spares.vo.*;
import cn.iocoder.yudao.module.ems.dal.dataobject.eqtype.EqTypeDO;
import cn.iocoder.yudao.module.ems.dal.dataobject.spares.SparesDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;

/**
 * 备品备件 Service 接口
 *
 * @author dason
 */
public interface SparesService {

    /**
     * 创建备品备件
     *
     * @param createReqVO 创建信息
     * @return 编号
     */
    Long createSpares(@Valid SparesCreateReqVO createReqVO);

    /**
     * 更新备品备件
     *
     * @param updateReqVO 更新信息
     */
    void updateSpares(@Valid SparesUpdateReqVO updateReqVO);

    /**
     * 删除备品备件
     *
     * @param id 编号
     */
    void deleteSpares(Long id);

    /**
     * 获得备品备件
     *
     * @param id 编号
     * @return 备品备件
     */
    SparesDO getSpares(Long id);

    /**
     * 获得备品备件列表
     *
     * @param ids 编号
     * @return 备品备件列表
     */
    List<SparesDO> getSparesList(Collection<Long> ids);

    /**
     * 获得备品备件分页
     *
     * @param pageReqVO 分页查询
     * @return 备品备件分页
     */
    PageResult<SparesDO> getSparesPage(SparesPageReqVO pageReqVO);

    /**
     * 获得备品备件列表, 用于 Excel 导出
     *
     * @param exportReqVO 查询条件
     * @return 备品备件列表
     */
    List<SparesDO> getSparesList(SparesExportReqVO exportReqVO);

    /**
     * 筛选备品备件类别列表
     *
     * @param reqVO 筛选条件请求 VO
     * @return 备品备件列表
     */
    List<SparesDO> getSimpleSpares(SparesListReqVO reqVO);


}
